package br.fatec.model.dao;

import java.util.HashMap;
import java.util.List;

import br.fatec.model.entity.Contato;
import br.fatec.util.Globals;
import br.fatec.util.Persistencia;

public class ContatoDao {
	private Persistencia persis;		
	
	public ContatoDao()
	{
		Globals globals = Globals.getInstance();
		
		this.persis = globals.getPersistencia();
	}
	
	public void cadastrar(Contato contato) throws Exception
	{	
		persis.cadastrar(contato);	
	}
	
	public void alterar(Contato contato) throws Exception
	{	
		persis.alterar(contato);
	}
	
	public void excluir(Contato contato) throws Exception
	{
		persis.excluir(contato.getClass(), contato.getCodigo());
	}
	
	public void desativar(Contato contato) throws Exception {
		contato = consultar(contato.getCodigo());
		
		contato.setAtivo(false);
		
		persis.alterar(contato);
	}
	
	public Contato consultar(Integer codigo) throws Exception
	{	
		String query = "select * from contato where codigo = :codigo and ativo = :ativo";
		
		HashMap<String, Object> parametros = new HashMap<String, Object>();
		parametros.put("codigo", codigo);
		parametros.put("ativo", true);
		
		return (Contato)persis.consultar(Contato.class, query, parametros);
	}
	
	@SuppressWarnings("unchecked")
	public List<Contato> listar() throws Exception
	{
		String query = "select * from contato where ativo = :ativo order by codigo asc";
		
		HashMap<String, Object> parametros = new HashMap<String, Object>();
		parametros.put("ativo", true);
		
		return (List<Contato>)persis.listar(Contato.class, query, parametros);
	}
}
